var prefix = "/yw/leave";
$(function () {
    selectLoad();
    load();
});

function selectLoad() {
    var html = "";
    $.ajax({
        url: prefix + '/leaveType',
        success: function (res) {
            if (res.code === 0) {
                var data = res.data;
                //加载数据
                for (var i = 0; i < data.length; i++) {
                    html += '<option value="' + data[i].value + '">' + data[i].name + '</option>'
                }
                $("#leaveType").append(html);
                $("#leaveType").chosen({
                    maxHeight: 200
                });
                //点击事件
                $('#leaveType').on('change', function (e, params) {
                    console.log(params.selected);
                    reLoad();
                });
            } else {
                layer.msg(res.msg);
            }
        }
    });
    var html1 = "";
    $.ajax({
        url: prefix + '/leaveSHType',
        success: function (res) {
            if (res.code === 0) {
                var data = res.data;
                //加载数据
                for (var i = 0; i < data.length; i++) {
                    html1 += '<option value="' + data[i].value + '">' + data[i].name + '</option>'
                }
                $("#leaveSHType").append(html1);
                $("#leaveSHType").chosen({
                    maxHeight: 200
                });
                //点击事件
                $('#leaveSHType').on('change', function (e, params) {
                    console.log(params.selected);
                    reLoad();
                });
            } else {
                layer.msg(res.msg);
            }
        }
    });
}


function load() {
    $('#exampleTable')
        .bootstrapTable(
            {
                method: 'get', // 服务器数据的请求方式 get or post
                url: prefix + "/leave/list", // 服务器数据的加载地址
                showRefresh: true,
                showToggle: true,
                iconSize: 'outline',
                toolbar: '#exampleToolbar',
                striped: true, // 设置为true会有隔行变色效果
                dataType: "json", // 服务器返回的数据类型
                pagination: true, // 设置为true会在底部显示分页条
                // queryParamsType : "limit",
                // //设置为limit则会发送符合RESTFull格式的参数
                singleSelect: false, // 设置为true将禁止多选
                // contentType : "application/x-www-form-urlencoded",
                // //发送到服务器的数据编码类型
                pageSize: 10, // 如果设置了分页，每页数据条数
                pageNumber: 1, // 如果设置了分布，首页页码
                search: false, // 是否显示搜索框
                showColumns: true, // 是否显示内容下拉框（选择显示的列）
                sidePagination: "server", // 设置在哪里进行分页，可选值为"client" 或者
                // "server"
                queryParams: function (params) {
                    return {
                        // 说明：传入后台的参数包括offset开始索引，limit步长，sort排序列，order：desc或者,以及所有列的键值对
                        limit: params.limit,
                        offset: params.offset,
                        agreeStatus: $('#leaveSHType').val(),
                        leaveType: $('#leaveType').val()
                    };
                },
                columns: [
                    {
                        field: 'id', // 列字段名
                        title: '编号', // 列标题
                        align: 'center',
                        valign: 'center'
                    },
                    {
                        field: 'userName',
                        title: '申请人姓名',
                        align: 'center',
                        valign: 'center'
                    },
                    {
                        field: 'leaveTypeName',
                        title: '请假类型',
                        align: 'center',
                        valign: 'center'
                    },
                    {
                        field: 'leaveStart',
                        title: '请假开始时间',
                        align: 'center',
                        valign: 'center'
                    },
                    {
                        field: 'leaveEnd',
                        title: '请假结束时间',
                        align: 'center',
                        valign: 'center'
                    },
                    {
                        field: 'agreeStatus',
                        title: '审核类型',
                        align: 'center',
                        formatter: function (value) {
                            if (value === 'leave_sh_type_ok') {
                                return '<span class="label label-success">审核通过</span>';
                            } else if (value === 'leave_sh_type_error') {
                                return '<span class="label label-primary">审核不通过</span>';
                            } else {
                                return '<span class="label label-warning">待审核</span>';
                            }
                        }
                    },
                    {
                        field: 'agreeUserName',
                        title: '同意人',
                        align: 'center',
                        formatter: function (value) {
                            if (value) {
                                return value;
                            } else {
                                return '未审核';
                            }
                        }
                    },
                    {
                        title: '操作',
                        field: 'id',
                        align: 'center',
                        formatter: function (value, row) {
                            var a = '<a  class="btn btn-primary btn-sm ' + s_edit_h + '" href="#" mce_href="#" title="审核" onclick="edit(\''
                                + row.id
                                + '\')"><i class="fa fa-edit ">审核</i></a> ';
                            var b = '<a  class="btn btn-warning btn-sm ' + s_remove_h + '" href="#" mce_href="#" title="审核" onclick="remove(\''
                                + row.id
                                + '\')"><i class="fa fa-remove">删除</i></a> ';
                            if (!row.agreeUserName) {
                                return a + b;
                            } else {
                                return b;
                            }
                        }
                    }]
            });
}

function reLoad() {
    $('#exampleTable').bootstrapTable('refresh');
}

function add() {
    layer.open({
        type: 2,
        title: '请假申请',
        maxmin: true,
        shadeClose: true, // 点击遮罩关闭层
        area: ['800px', '520px'],
        content: prefix + '/add'
    });
}

function edit(id) {
    console.log(id);
    layer.open({
        type: 2,
        title: '请假申请',
        maxmin: true,
        shadeClose: true, // 点击遮罩关闭层
        area: ['800px', '520px'],
        content: prefix + '/edit/' + id
    });
}

function remove(id) {
    layer.confirm('确定要删除选中的记录？', {
        btn: ['确定', '取消']
    }, function () {
        $.ajax({
            url: prefix + '/remove/' + id,
            type: "GET",
            success: function (r) {
                layer.msg(r.msg);
                if (r.code === 0) {
                    reLoad();
                }
            }
        });
    })
}